@charset "utf-8";

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
select,
textarea,
input[type="password"],
input[type="text"] {
    outline: none;
    -webkit-appearance: none;
}
input[type="button"],
input[type="submit"] {
    outline: none;
    -webkit-appearance: none;
}
img {
    color: transparent;
    text-decoration: none;
    vertical-align: bottom;
}
a:link { -webkit-tap-highlight-color: rgba(0,0,0,0); }
::-webkit-input-placeholder { /* WebKit browsers */
    color: #ddd;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    color: #ddd;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
    color: #ddd;
}
:-ms-input-placeholder { /* Internet Explorer 10+ */
    color: #ddd;
}
body{
    background: #fbf7ed;
    padding: 0;
    color: #5c5c5c;
    font: 14px arial;
    line-height: 1.5;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}
header{
}
h1{
    font-size: 20px;
    /* color: #4abdcc; */
    color: #5c5c5c;
    padding-bottom: 15px;
    border-bottom: 1px solid #c9c9c9;
    margin: 15px;
    line-height: 1;
}
h1 i{
    vertical-align: text-top;
    margin-right: 5px;
}
h2{
    font-size: 18px;
    color: #4ABDCC;
    margin: 15px 0;
    line-height: 1;
}
h2 i{
    vertical-align: text-top;
    margin-right: 5px;
}
section{
    margin: 15px;
}
section strong{
    font-weight: bold;
}
.big-price {
    margin-top: 15px;
    height: 0;
    width: 90px;
    float: right;
    color: white;
    background-color: #f36700;
    height: 49px;
    font-size: 14px;
}
.big-price p{
    float: left;
    width: 70px;
    height: 16px;
    margin-top: 3px;
}
.big-price:before {
    content: "";
    float: left;
    display: inline-block;
    width: 9px;
    border-top: 25px solid #f36700;
    border-bottom: 24px solid #f36700;
    border-left: 9px solid #fbf7ed;
}
.big-price .big-price-qj,
.big-price .big-price-ydj {
    font-size: 8px;
    padding-left: 12px;
}
.big-price-ec {
    -webkit-text-size-adjust: 8px;
    font-style: italic;
    font-size: 6px;
    border: 1px solid #fff;
    margin-top: 2px;
    margin-left: 12px;
    padding: 0 2px;
    border-bottom-left-radius: 3px;
    border-bottom-right-radius: 3px;
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    -webkit-transform: skew(-8deg);
    transform: skew(-8deg);
    box-shadow: 0 2px rgb(213, 90, 0);
}
.big-price-number {
    font-size: 16px;
    font-weight: bold;
    font-style: italic !important;
}
.big-price .icon-yuan {
    font-size: 12px;
}
.trip-title {
    padding-right: 80px;
    font-size: 20px;
    line-height: 1.2em;
    min-height: 2em;
    word-wrap: break-word;
}
.trip-summary {
    list-style-type: disc;
    margin-left: 20px;
    font-size: 20px;
    color: #999;
}
.trip-summary li{
    line-height: 20px;
}
.trip-summary li p{
    color: rgb(92, 92, 92);
    font-size: 14px;
    margin: 0 0 0 -8px;
}
.trip-summary-title {
    display: inline-block;
    width: 4.5em;
    height: 1.2em;
    overflow: hidden;
    text-align:justify;
    text-justify:distribute-all-lines;/*ie6-8*/
    text-align-last:justify;/* ie9*/
    -moz-text-align-last:justify;/*ff*/
    -webkit-text-align-last:justify;/*chrome 20+*/
}
@media screen and (-webkit-min-device-pixel-ratio:0){/* chrome*/
    .trip-summary-title::after {
        content:".";
        display: inline-block;
        width:100%;
        overflow:hidden;
        height:0;
    }
}

.box{
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    border: 1px solid #c9c9c9;
    padding: 9px;
}
.box h2{
    color: #5C5C5C;
    font-size: 16px;
    border-bottom: 1px solid #c9c9c9;
    padding-top: 2px;
    padding-bottom: 10px;
    margin: 0 0 7px;
}
.box p{
    margin: 5px 0;
}
.box img{
    width: 100%;
    margin: 5px 0;
    height: auto;
}
.box table{
    border-collapse: separate;
    background: #C9C9C9;
    border-spacing: 1px;
    width: 100%;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    line-height: 1.5;
}
.box tr{
    background: #FBF7ED;
}
.box td{
    padding: 10px;
}
.box table tr:first-child td:first-child{
    -webkit-border-top-left-radius: 4px;
    border-top-left-radius: 4px;
}
.box table tr:first-child td:last-child{
    -webkit-border-top-right-radius: 4px;
    border-top-right-radius: 4px
}
.box table tr:last-child td:first-child{
    -webkit-border-bottom-left-radius: 4px;
    border-bottom-left-radius: 4px;
}
.box table tr:last-child td:last-child{
    -webkit-border-bottom-right-radius: 4px;
    border-bottom-right-radius: 4px
}
b{
    font-weight: bold;
}
.intro{
    font-size: 10px;
    color: #999;
    line-height: 1;
    text-align: justify;
}
.intro table{
    width: 100%;
}
.intro td{
    /*width: 25%;*/
    min-width: 52px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 13px;
    border-left: 1px dotted #C9C9C9;
}
.intro td:first-child{
    border-left: none;
    padding-left: 0;
}
.intro td:last-child{
    padding-right: 0;
    /*width: 20%;*/
}
.intro p b{
    display: block;
    margin-bottom: 6px;
    font-size: 12px;
    font-weight: bold;
    color: #5c5c5c;
}
.intro strong{
    font-size: 20px;
}
.intro .price{
    color: #fc5d7b;
}
.intro .num{
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
    margin-top: 0;
}
h3{
    color: #B9A67E;
    text-align: center;
    font-size: 16px;
    margin: 5px 0;
    line-height: 1;
}
h4{
    text-align: center;
    font-size: 16px;
    line-height: 16px;
    color: #5c5c5c;
    margin: 7px 0 10px;
}
h4 i{
    vertical-align: text-top;
    margin: 0 7px;
    width: 17px;
    height: 16px;
    position: relative;
    top: 2px;
}
.hidden{
    display: none;
}
.text-error{
    color: #FC5D7B;
}
.text-center{
    text-align: center;
}
.btn-primary{
    display: inline-block;
    text-align: center;
    font-size: 10px;
    color: #fff;
    height: 20px;
    line-height: 20px;
    border-bottom-right-radius: 20px;
    border-bottom-left-radius: 20px;
    border-top-right-radius: 20px;
    border-top-left-radius: 20px;
    -webkit-border-radius: 20px;
    border-radius: 20px;
    text-decoration: none;
    background: #5acbda;
    padding: 0 8px;
    border: 1px solid #2e9dab;
    -webkit-text-size-adjust: none;
}
.btn-muted{
    background: #c9c9c9;
    border: 1px solid #b0b0b0;
    color: #fff;
    cursor: default;
}
.btn-disable{
    background: #7c7b7a;
    border: 1px solid #999;
    color: #fff;
    cursor: default;
}

/* popup */
.popup{
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 999;
    padding: 15px;
    box-sizing: border-box;
}
.popup-mask{
    background: rgba(0, 0, 0, 0.6);
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}
.popup-inner{
    z-index: 10;
    position: relative;
    top: 100px;
    background: #FBF7ED;
    padding: 15px;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    text-align: center;
}
.popup h4{
    text-align: left;
    line-height: 20px;
    border-bottom: 1px solid #C9C9C9;
    padding-bottom: 12px;
    margin: 0 0 15px;
}
.popup h4 a{
    float: right;
}
.popup h5{
    font-size: 19px;
    font-weight: bold;
}
.popup p b{
    color: #4abdcc;
}

/* icon base:/static/img/mobile_tp/icons.png */
.icon,
.detail-title::after,
.popup-cart-coupon-error::after,
.products .title::after,
.flight-departure::after{
    background-image: url(/static/img/mobile_tp/icons.png?v=140418);
    background-size: 20px 515px;    
}
.icon{
    background-repeat: no-repeat;
    display: inline-block;
}
.icon-flight{
    background-position: 0 -36px;
    width: 17px;
    height: 16px;
}
.icon-info{
    background-position: 0 -19px;
    width: 16px;
    height: 17px;
}
.icon-arrow{
    background-position: 0 -74px;
    width: 8px;
    height: 13px;
}
.icon-info2{
    background-position: 0 -96px;
    width: 20px;
    height: 21px;
}
.icon-money{
    background-position: 0 -117px;
    width: 20px;
    height: 21px;
}
.icon-date{
    background-position: 0 -138px;
    width: 14px;
    height: 14px;
}
.icon-people{
    background-position: 0 -153px;
    width: 14px;
    height: 14px;
}
.icon-tel{
    background-position: 0 -168px;
    width: 9px;
    height: 14px;
}
.icon-profile{
    background-position: 0 -183px;
    width: 14px;
    height: 14px;
}
.icon-user{
    background-position: 0 -198px;
    width: 20px;
    height: 21px;
}
.icon-order{
    background-position: 0 -219px;
    width: 20px;
    height: 21px;
}
.icon-error{
    background-position: 0 -240px;
    width: 15px;
    height: 16px;
}
.icon-mail{
    background-position: 0 -269px;
    width: 15px;
    height: 10px;
}
.icon-id{
    background-position: 0 -256px;
    width: 15px;
    height: 12px;
}
.icon-pen{
    background-position: 0 -279px;
    width: 13px;
    height: 13px;
}
.icon-yes{
    background-position: 0 -293px;
    width: 20px;
    height: 21px;
}
.icon-rmb{
    background-position: 0 -314px;
    width: 12px;
    height: 14px;
}
.icon-dollar{
    background-position: 0 -329px;
    width: 10px;
    height: 15px;
}
.icon-more{
    background-position: 0 -353px;
    width: 20px;
    height: 21px;
}
.icon-bg{
    background-position: 0 -374px;
    width: 20px;
    height: 20px;
}
.icon-exchange{
    background-position: 0 -395px;
    width: 20px;
    height: 21px;
}
.icon-close{
    background-position: 0 -416px;
    width: 19px;
    height: 20px;
}
.icon-type{
    background-position: 0 -436px;
    width: 15px;
    height: 12px;
}
.icon-house{
    background-position: 0 -449px;
    width: 16px;
    height: 15px;
}
.icon-gotoarrow{
    background-position: 0 -464px;
    width: 12px;
    height: 12px;
}
.icon-flight-departure{
    background-position: 0 -477px;
    width: 15px;
    height: 9px;
}
.icon-flight-destination{
    background-position: 0 -486px;
    width: 15px;
    height: 9px;
}
.icon-mobile
.justify_fix{
    width: 100%!important;
    height: 0;
    overflow: hidden;
}
.dayhr{
    height: 20px;
    line-height: 20px;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    background-image: url(/static/img/mobile_tp/h3bg.png);
    background-repeat: repeat-x;
    background-size: 1px 4px;
    background-position: center center;
}
.dayhr i{
    display: inline-block;
    padding: 0 10px;
    background-color: #fbf7ed;
    width: 20px;
    height: 20px;
}

/***************/

.border-star .box{
    border: 1px solid #f36700;
    background: transparent url(/static/img/mobile_tp/box_star.png) no-repeat right top;
    background-size: 37px 37px;
}
.border-star .box article{
    border-top: 0;
}
.border-star .box h2 {
    padding-right: 20px;
}

.calendar-title {
    padding: 0;
}
.calendar-title a{
    text-decoration: none;
}
.calendar-title h2{
    border: 0;
    margin: 0;
    padding: 0 0 0 9px;
    height: 36px;
    line-height: 36px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    color: #5acbda;
}
.calendar-title h2 font,
.calendar-title h2 b{
    color: #5C5C5c;
}

.calendar-title span.calendar-date{
    color: #5acbda;
    margin-left: 9px;
}
.introduce{
    padding-bottom: 40px;
}
.schedule {
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
}
.schedule .article {
    border-bottom: 1px dotted #e6e6e6 !important;
}
.detail-title{
    overflow: hidden;
    -webkit-border-top-right-radius: 4px;
    -webkit-border-top-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    padding: 0;
    padding-right: 30px;
    font-size: 16px;
    margin: 0 !important;
    position: relative;
}
.detail-title::after{
    content: "";
    width: 12px;
    height: 8px;
    display: block;
    position: absolute;
    right: 14px;
    top: 50%;
    margin-top: -4px;
    background-position: 0 -345px;
    background-repeat: no-repeat;
}
.detail article {
    word-wrap: break-word;
    margin-top: 5px;
    padding-top: 5px;
    border-top: 1px solid #c9c9c9;
}
.detail-hide article {
    display: none;
}
.detail-hide .detail-title::after{
    background-position: 0 -88px;
}
.schedule dl:not(:first-child){
    padding-top: 9px;
    border-top: 1px dotted #C9C9C9;
    margin-top: 9px;
}
.schedule-dotted-divider{
    height: 0;
    margin: 15px;
    border-bottom: 1px dotted #c9c9c9;
}
.similar-product .color-red{
    color: #fc5d7b;
}
.similar-product article p{
    padding-bottom: 3px;
    border-bottom: 1px dotted #c9c9c9;
}
.similar-product article p:last-child{
    border-bottom: 0;
}
.similar-product article a {
    color: #5c5c5c;
    text-decoration: none;
}
.similar-product article p:hover a{
    color: #5acbda;
}
.similar-product article p:active a{
    color: #5acbda;
}

.detail .detail-item{
    padding: 10px 0;
    display: table;
    width: 100%;
    border-bottom: 1px dotted #c9c9c9;
}
.detail .detail-item:last-child{
    border-bottom: none;
}
.detail .detail-item-title{
    float: left;
    display: block;
    font-size: 15px;
    margin: 0;
    line-height: 1.2em;
    width: 35px;
    height: auto;
    border-right: 1px solid #c9c9c9;
    padding-top: 1px;
}
.detail .detail-item-content{
    margin-left: 42px;
}
.detail .detail-item-content p{
    margin: 0;
}

.flight{}
.flight-item li{
    overflow: hidden;
    line-height: 1;
    padding: 15px 0 15px 1px;
    position: relative;
    border-bottom: 1px dotted #c9c9c9;
}
.flight-item li:last-child{
    border-bottom: none;
}
.flight-item p{
    margin: 0;
}
.flight-item dt{
    float: left;
    /*width: 41px;*/
    color: #999;
    text-align: center;
}
.flight-item dt i{
    margin-right: 3px;
}
.flight-item .flight-direction{
    font-size: 13px;
    border-bottom: 1px solid #e7e7e7;
    padding-top: 3px;
    padding-bottom: 6px;
}
.flight-item .flight-date{
    font-size: 15px;
    padding-top: 8px;
}
.flight-item dd{
    float: left;
    padding-left: 18px;
    /*width: 41px;*/
}
.flight-num{
    padding-bottom: 6px;
}
.flight-time{
    overflow: hidden;
}
.flight-num{
    font-size: 18px;
}
.flight-time div{
    float: left;
}
.flight-time p+p{
    color: #999;
    font-size: 10px;
    margin-top: 3px;
}
.flight-departure{
    margin-right: 25px;
    position: relative;
}
.flight-departure::after{
    content: '';
    width: 13px;
    height: 12px;
    background-position: 0 -495px;
    position: absolute;
    right: -20px;
    top: 1px;
}
.flight-item .flight-has-stop{
    font-size: 12px;
    color: #999;
    background-color: #e7e7e7;
    width: 44px;
    height: 22px;
    text-align: center;
    line-height: 22px;
    float: none;
    padding-left: 0;
    position: absolute;
    right: 0;
    top: 50%;
    margin-top: -11px;
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
    border-bottom-left-radius: 3px;
    border-bottom-right-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

.thumbnail{
    margin: 9px;
}
.thumbnail ul{
    margin: 0;
    width: 100%;
    text-align: justify;
}
.thumbnail li{
    display: inline-block;
    width: 32%;
    text-align: center;
}
.thumbnail li a{
    display: inline-block;
    width: 84px;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
}
.thumbnail li img{
    margin: 0;
    width: 84px;
}
.thumbnail .btn{
    float: right;
    margin-top: -14px;
}
.schedule article{
    margin: 9px;
}
.schedule article p{
    margin: 5px 0;
}
.swipe {
  overflow: hidden;
  visibility: hidden;
  position: relative;
  max-height: 300px;
}
.swipe-wrap {
  overflow: hidden;
  position: relative;
}
.swipe-wrap > div {
  float: left;
  width: 100%;
  position: relative;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover;
}
.swipe .holder{
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    margin: 0;
}
header .video{
    position: relative;
}
header .video iframe{
    position: absolute;
    left: 0;
    top: 0;
}
header .video img{
    width: 100%;
}
.swipe-wrap img{
    width: 100%;
}
.slider-position{
    position: absolute;
    bottom: 13px;
    left: 0;
    width: 100%;
    line-height: 1;
    text-align: center;
}
.slider-position li{
    width: 11px;
    height: 11px;
    display: inline-block;
    margin: 0 3px;
    background-image: url(/static/img/mobile_tp/points.png);
    background-size: 12px 25px;
    background-position: 0 0;
    background-repeat: no-repeat;
}
.slider-position .on{
    background-position: 0 -13px;
}
.affix{
    position: fixed;
    bottom: 0;
    left: 0;
    height: 46px;
    line-height: 46px;
    text-align: center;
    width: 100%;
    color: #fff;
    background-color: rgba(92,92,92,.9);
}
.affix .icon-info{
    color: #fff;
    height: 17px;
    line-height: 17px;
    text-decoration: none;
    padding: 0 0 0 20px;
    width: auto;
}
.affix .btn-primary{
    margin-left: 33px;
    font-size: 16px;
    height: 32px;
    line-height: 32px;
    padding: 0 30px;
    border-bottom-right-radius: 32px;
    border-bottom-left-radius: 32px;
    border-top-right-radius: 32px;
    border-top-left-radius: 32px;
    -webkit-border-radius: 32px;
    border-radius: 32px;
    margin: 0 10px;
}
.affix .btn-hollow {
    background: transparent;
    border-width: 2px;
    color: #5acbda;
}
.affix .icon-arrow{
    height: 15px;
    width: 8px;
    margin-left: 18px;
    vertical-align: text-top;
    background-position: 0 -73px;
}

/* Sub Products */
.sub-products{
    padding-bottom: 6px;
}
.sub-products li{
    overflow: hidden;
    margin: 10px 0 5px;
}
.sub-products p{
    margin: 0;
}
.sub-products-price{
    float: right;
    width: 71px;
    box-sizing: border-box;
    padding-left: 8px;
    border-left: 1px dotted #C9C9C9;
    height: 79px;
    text-align: center;
}
.sub-products-price.noprice{
    height: 36px;
}
.sub-products-price p{
    font-weight: bold;
    font-size: 18px;
    padding: 9px 0 11px;
    line-height: 1;
}
.sub-products-price span{
    font-size: 9px;
    font-weight: normal;
    position: relative;
    top: -3px;
}
.sub-products-price .btn-primary{
    line-height: 25px;
    height: 25px;
    padding: 0 13px;
    font-size: 12px;
}
.sub-products-pic{
    float: left;
    padding-right: 10px;
}
.sub-products-pic img{
    width: 79px;
    height: 79px;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    margin: 0;
}
.sub-products-title{
    overflow: hidden;
    font-size: 15px;
    padding-top: 6px;
    padding-right: 10px;
}

/* Booking page */
.booking-msg{
    font-size: 17px;
}
.booking h2{
    margin: 25px 0 15px;
}
.booking-info{
    margin-bottom: 15px;
}
.booking-payment{
    background: #fff;
    border: 1px solid #C9C9C9;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    margin: 15px 0;
    padding: 5px 14px;
}
.booking-payment i{
    font-size: 14px;
    color: #999;
}
.booking-payment table,
.popup-cart-content table{
    width: 100%;
    font-size: 16px;
}
.booking-payment td{
    height: 30px;
    line-height: 30px;
}
.booking-payment tr td:first-child,
.popup-cart-content tr td:first-child{
    text-align: left;
}
.booking-payment tr td:last-child,
.popup-cart-content tr td:last-child{
    text-align: right;
}
.booking-payment hr,
.popup-cart-content hr{
    height: 1px;
    background: none;
    border: none;
    border-bottom: 1px dotted #C9C9C9;
}
.booking-payment strong,
.popup-cart-content strong{
    color: #F95F7D;
    font-weight: bold;
}
.booking-payment .btn-primary{
    background: #fff;
    color: #4abdcc;
}
.booking-payment .btn-primary:active{
    background: #5ACBDA;
    color: #fff;
}
.booking-payment span,
.popup-cart-content span{
    margin-right: 5px;
}
.booking-payment strong,
.popup-cart-content strong{
    color: #fc5d7b;
    font-weight: bold;
}
.popup-cart-content i{
    font-size: 14px;
    color: #b0b0b0;
}
.popup-cart-points input,
.popup-cart-coupon input{
    background: #fff;
    border: 1px solid #c9c9c9;
    box-sizing: border-box;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    line-height: normal;
    font-size: 16px;
}
.popup-cart-points input{
    padding: 0 4px 0 5px;
    text-align: right;
    width: 63px;
    height: 25px;
}
.popup-cart-coupon input{
    width: 100%;
    height: 30px;
    padding: 0 10px;
    margin-top: 7px;
}
.popup-cart-coupon-info{
    margin-top: 5px;
    display: none;
}
.popup-cart-btn{
    display: block;
    width: 100px;
    margin: 13px auto 10px;
    font-size: 20px;
    height: 34px;
    line-height: 34px;
    border-bottom-right-radius: 34px;
    border-bottom-left-radius: 34px;
    border-top-right-radius: 34px;
    border-top-left-radius: 34px;
    -webkit-border-radius: 34px;
    border-radius: 34px;
}
.popup-cart-notuse{
    display: block;
    text-align: center;
    margin: 10px 0 0;
    font-size: 14px;
    color: #4abdcc;
}

.booking-form dl{
    border-bottom: 1px solid #C9C9C9;
    padding-bottom: 10px;
}
.booking-form dt{
    float: left;
}
.booking-form dd{
    overflow: hidden;
}
.booking-form dd span{
    margin-left: 18px;
}
.booking-form form table{
    border-collapse: separate;
    background: #C9C9C9;
    border-spacing: 1px;
    width: 100%;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    margin-bottom: 15px;
}
.booking-form form tr{
    background: #FBF7ED;
}
.booking-form form th{
    text-align: left;
    font-size: 16px;
    text-indent: 21px;
}
.booking-form form td,
.booking-form form th{
    /*border: 1px solid #C9C9C9;*/
    height: 45px;
    line-height: 45px;
}
.booking-form form tr td:first-child{
    min-width: 110px;
}
.booking-form form tr td:last-child{
    background-color: #fff;
}
.booking-form form table tr:first-child td:first-child,
.booking-form form table tr:first-child th{
    -webkit-border-top-left-radius: 4px;
    border-top-left-radius: 4px;
}
.booking-form form table tr:first-child td:last-child,
.booking-form form table tr:first-child th{
    -webkit-border-top-right-radius: 4px;
    border-top-right-radius: 4px
}
.booking-form form table tr:last-child td:first-child{
    -webkit-border-bottom-left-radius: 4px;
    border-bottom-left-radius: 4px;
}
.booking-form form table tr:last-child td:last-child{
    -webkit-border-bottom-right-radius: 4px;
    border-bottom-right-radius: 4px
}
.booking-form label{
    padding-left: 18px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.booking-form label i{
    width: 25px;
    vertical-align: middle;
    margin-top: -3px;
}
.booking-form .icon-tel{
    background-position: 2px -168px;
}
.booking-form input[type="text"],
.booking-form input[type="tel"],
.booking-form input[type="number"],
.booking-form input[type="date"],
.booking-form input[type="email"]{
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    color: #999;
    font-size: 16px;
    width: 80%;
    padding: 0;
    margin: 0;
    border: none;
    box-sizing: border-box;
    margin-left: 13px;
    outline: none;
}
.booking-form input[type="submit"]{
    display: block;
    width: 190px;
    margin: 19px auto;
    font-size: 20px;
    height: 45px;
    line-height: 45px;
    border-bottom-right-radius: 45px;
    border-bottom-left-radius: 45px;
    border-top-right-radius: 45px;
    border-top-left-radius: 45px;
    -webkit-border-radius: 45px;
    border-radius: 45px;
}
.booking-form select{
    border: none;
    color: #999;
    font-size: 16px;
    margin-left: 13px;
    width: 80%;
    padding-left: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-image: url(/static/img/mobile_tp/icon_select.png);
    background-size: 12px 8px;
    background-repeat: no-repeat;
    background-position: 95% center;
}
.booking-form-price p{
    color: #999;
    font-size: 16px;
    padding-left: 13px;
}
.booking-form-price a{
    float: right;
    margin-right: 13px;
    margin-top: 12px;
}
.booking-form-price span{
    padding-left: 9px;
    margin-left: 9px;
    font-weight: bold;
    color: #4ABDCC;
    border-left: 1px dotted #C9C9C9;
}
.booking-form .icon-error{
    display: none;
}
.booking-form p{
    position: relative;
}
.booking-form-error{
    position: relative;
    color: #fc5d7b;
}
.booking-form-error input{
    color: #fc5d7b!important;
}
.booking-form-error .icon-error{
    position: absolute;
    right: 13px;
    top: 14px;
    display: block;
}
.booking-total{
    margin: 20px 0;
}
.booking-total b{
    font-size: 16px;
}
.booking-total strong{
    color: #4abdcc;
}
.booking-agreement,
.booking-coupon{
    display: block;
    margin-top: 20px;
    height: 23px;
    line-height: 23px;
    font-size: 16px;
    position: relative;
    overflow: hidden;
    padding-left: 10px;
}
.booking-coupon{
    padding-left: 0;
    margin-top: 0;
}
.booking-agreement label,
.booking-coupon label{
    display: block;
    padding-left: 30px;
    cursor: pointer;
    -moz-transition: color 1s ease;
    -o-transition: color 1s ease;
    -webkit-transition: color 1s ease;
    transition: color 1s ease;
}
.booking-agreement input,
.booking-coupon input{
    padding: 0;
    margin: 0;
    height: 20px;
    width: 20px;
    float: left;
    position: absolute;
    left: 0;
    opacity: 0;
}
.booking-agreement > input[type=checkbox] + label,
.booking-coupon > input[type=checkbox] + label{
    background: url(/static/img/mobile_tp/checkbox.png) 0 -74px no-repeat;
    background-size: 24px 97px;
    height: 23px;
}
.booking-agreement > input[type=checkbox]:checked + label,
.booking-coupon > input[type=checkbox]:checked + label{
    background: url(/static/img/mobile_tp/checkbox.png) 0 -50px no-repeat;
    background-size: 24px 97px;
    height: 23px;
}
.popup-cart-coupon-error{
    position: relative;
}
.popup-cart-coupon-error::after{
    content: "";
    width: 15px;
    height: 16px;
    display: block;
    position: absolute;
    right: 10px;
    bottom: 7px;
    background-position: 0 -240px;
    background-repeat: no-repeat;
}
.booking-agreement a{
    color: #4abdcc;
    text-decoration: underline;
    margin-left: 5px;
}
.popup-booking-inner .btn-primary{
    font-size: 16px;
    height: 33px;
    line-height: 33px;
    padding: 0 20px;
    margin: 20px 0 0;
}
.popup-alert{
    display: none;
}
.popup-comfirm{
    font-size: 16px;
    display: none;
}
.popup-comfirm-btn{
    overflow: hidden;
    font-size: 16px;
    padding: 20px 0 10px;
}
.popup-comfirm-btn a{
    height: 33px;
    line-height: 33px;
    width: 90px;
    font-size: 16px;
}
.popup-comfirm-btn a:first-child{
    float: left;
}
.popup-comfirm-btn a:last-child{
    float: right;
}
.popup-loading{
    width: 55px;
    height: 55px;
    text-align: center;
    background-color: rgba(51,51,51,.9);
    position: fixed;
    top: 100px;
    left: 50%;
    margin-left: -28px;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    -webkit-border-radius: 5px;
    border-radius: 5px;
}
.popup-loading img{
    width: 20px;
    position: relative;
    top: 16px;
    margin: 0;
    padding: 0;
}
.wxpay-callback-popup{
    display: none;
}
.wxpay-callback-popup .popup-inner{
    padding-top: 30px;
}
.wxpay-callback-popup .btn-primary{
    padding: 0 28px;
}
#popup-complete-btn{
    margin-right: 12px;
}
.popup-wxpay-close{
    text-indent: -9999em;
    position: absolute;
    top: 15px;
    right: 15px;
}
.booking-form > .btn-primary{
    background: #fc6e51;
    height: 45px;
    line-height: 45px;
    border: 1px solid #e9573f;
    font-size: 20px;
    border-bottom-right-radius: 40px;
    border-bottom-left-radius: 40px;
    border-top-right-radius: 40px;
    border-top-left-radius: 40px;
    -webkit-border-radius: 40px;
    border-radius: 40px;
    display: block;
    width: 190px;
    margin-left: auto;
    margin-right: auto;
}
.booking-form .btn-primary img{
    vertical-align: middle;
    margin: -4px 5px 0;
    width: 63px;
    height: 19px;
}
.booking-form > .btn-primary2{
    background: #5ACBDA;
    border: 1px solid #2E9DAB;
}
.booking-form .btn-info{
    background: #C9C9C9;
    height: 45px;
    line-height: 45px;
    border: 1px solid #b0b0b0;
    font-size: 20px;
    border-bottom-right-radius: 40px;
    border-bottom-left-radius: 40px;
    border-top-right-radius: 40px;
    border-top-left-radius: 40px;
    -webkit-border-radius: 40px;
    border-radius: 40px;
    display: block;
    width: 190px;
    margin-left: auto;
    margin-right: auto;
    color: #fff;
}
.booking-successed{
    text-align: center;
    font-size: 16px;
}
.booking-successed-img{
    padding: 65px 0 40px;
}
.booking-successed-img img{
    width: 162px;
    height: 140px;
}
.booking-successed-text{
    font-weight: bold;
    margin-bottom: 10px;
    padding: 0 15px;
}
.booking-successed p a{
    color: #4abdcc;
    font-weight: bold;
}
.booking-successed-contect{
    color: #4abdcc;
    margin: 18px 0;
}
.booking-successed-contect a{
    color: #4abdcc;
}
.booking-successed .btn-primary,
.booking-failure .btn-primary{
    font-size: 20px;
    width: 190px;
    height: 45px;
    line-height: 45px;
    margin: 18px auto;
    border-bottom-right-radius: 45px;
    border-bottom-left-radius: 45px;
    border-top-right-radius: 45px;
    border-top-left-radius: 45px;
    -webkit-border-radius: 45px;
    border-radius: 45px;
}
.booking-btn-title{
    text-align: center;
    position: relative;
    border-top: 1px solid #C9C9C9;
    margin: 25px 0 14px;
    line-height: 1;
}
.booking-btn-title b{
    display: inline-block;
    font-size: 14px;
    color: #5c5c5c;
    padding: 0 10px;
    background: #FBF7ED;
    position: relative;
    top: -7px;
}
.booking-btn{
    display: -webkit-box;
    display: box;
    -webkit-box-pack: justify;
    box-pack: justify;
}
.booking-btn-payment{
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
    -webkit-border-radius: 6px;
    border-radius: 6px;
    background-color: #4ABDCC;
    border: 1px solid #2E9DAB;
    height: 42px;
    padding-top: 11px;
    line-height: 1;
    color: #fff;
    text-decoration: none;
    display: block;
    width: 30%;
    text-align: center;
}
.booking-btn-2 .booking-btn-payment{
    width: 48%;
}
.booking-btn-payment i{
    width: 68px;
    height: 21px;
    display: inline-block;
    background-image: url(/static/img/mobile_tp/payment.png);
    background-repeat: no-repeat;
    background-size: 68px 100px;
    margin-bottom: 7px;
}
.booking-btn-payment .alipay{
    background-position: 0 2px;
}
.booking-btn-payment .unionpay{
    background-position: 0 -39px;
}
.booking-btn-payment .weixin{
    background-position: 0 -78px;
}
.booking-btn-payment span{
    display: block;
    font-size: 8px;
    -webkit-text-size-adjust: none;
}
.popup-share textarea{
    width: 100%;
    height: 90px;
    font-size: 14px;
    line-height: 1.5;
    border: 1px solid #c9c9c9;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    padding: 6px;
    box-sizing: border-box;
    margin: 0;
}
.sns{
    display: inline-block;
    width: 30px;
    height: 30px;
    text-indent: -8964em;
    background-image: url(/static/img/mobile_tp/sns.png);
    background-size: 30px 185px;
    margin-right: 8px;
}
.sns-sina{
    background-position: 0 0;
}
.sns-sina-active{
    background-position: 0 -31px;
}
.sns-qq{
    background-position: 0 -62px;
}
.sns-qq-active{
    background-position: 0 -93px;
}
.sns-tencent{
    background-position: 0 -124px;
}
.sns-tencent-active{
    background-position: 0 -155px;
}
.popup-share-btn{
    overflow: hidden;
    margin-top: 10px;
}
.popup-share-sns{
    float: left;
}
.popup-share .btn-primary{
    width: 80px;
    line-height: 28px;
    font-size: 14px;
    height: 28px;
    margin: 0;
    float: right;
}
.booking-failure-img{
    margin-top: 60px;
    margin-bottom: -70px;
    z-index: 1;
    padding: 0 10px;
    overflow: hidden;
}
.booking-failure-img img{
    width: 100%;
    margin-left: 15%;
}
.booking-failure p{
    text-align: center;
    font-size: 16px;
}
.booking-failure p a{
    color: #4abdcc;
    margin: 0 5px;
}
.booking-failure .btn-primary{
    display: block;
    position: relative;
    z-index: 10;
    margin-top: 30px;
}


/* explain */
.explain nav{
    text-align: center;
    height: 40px;
    line-height: 40px;
    border-bottom: 1px solid #C9C9C9;
    margin: -15px 15px 15px;
}
.explain nav a{
    display: inline-block;
    color: #999;
    height: 25px;
    line-height: 25px;
    text-decoration: none;
    padding: 0 18px;
    border-left: 1px dotted #C9C9C9;
}
.explain nav a:first-child{
    border-left: none;
}
.explain nav .on{
    color: #5c5c5c;
    position: relative;
}
.explain nav .on::before{
    content: "";
    width: 0px;
    height: 0px;
    border-width: 8px;
    border-style: solid;
    border-color: #C9C9C9 transparent transparent transparent ;
    position: absolute;
    bottom: -23px;
    right: 50%;
    margin-right: -8px;
}
.explain nav .on::after{
    content: "";
    width: 0px;
    height: 0px;
    border-width: 8px;
    border-style: solid;
    border-color: #FBF7ED transparent transparent transparent ;
    position: absolute;
    bottom: -22px;
    right: 50%;
    margin-right: -8px;
}
.explain .btn-primary{
    display: block;
    margin: 15px auto;
    font-size: 16px;
    height: 30px;
    line-height: 30px;
    width: 100px;
}
.booking-suc{
    margin: 0;
}

/* exchange */
.exchange-tip .box{
    border-style: dotted;
    font-size: 16px;
}
.exchange-tip .box b{
    font-weight: bold;
    color: #4abdcc;
    margin: 0 5px;
}
.exchange-tip .box a{
    display: block;
    width: 119px;
    height: 33px;
    line-height: 33px;
    font-size: 16px;
    margin: 5px auto;
}

/* products */
.products{
    margin: 15px 0;
    border: 1px solid #C9C9C9;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
}
.products .box{
    padding: 0;
}
.products .title{
    height: 43px;
    line-height: 43px;
    font-size: 16px;
    padding-left: 14px;
    margin: 0;
    background: #fff;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    position: relative;
    cursor: pointer;
}
.products .title::after{
    content: "";
    width: 12px;
    height: 8px;
    display: block;
    position: absolute;
    right: 14px;
    top: 50%;
    margin-top: -4px;
    background-position: 0 -345px;
    background-repeat: no-repeat;
}
.products-jifen .title{
    cursor: default;
}
.products-jifen .title::after{
    display: none;
}
.products li{
    padding: 14px;
    border-top: 1px solid #C9C9C9;
    position: relative;
}
.products a{
    color: #5C5C5C;
    display: block;
    overflow: hidden;
    text-decoration: none;
}
.products p{
    font-size: 14px;
    margin: 0;
    line-height: 1;
}
.products .pic{
    float: left;
    margin-right: 10px;
}
.products .info{
    overflow: hidden;
}
.products img{
    width: 75px;
    margin: 0;
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
}
.products .name{
    font-size: 16px;
    height: 34px;
    margin-bottom: 10px;
    line-height: 1.1;
    position: relative;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    top: -1px;
}
.products .price{
    margin: 0 0 4px;
}
.products-jifen .price{
    color: #b0b0b0;
}
.products-jifen .price b{
    font-weight: normal;
}
.products .convert{
    color: #4abdcc;
}
.products-jifen .convert{
    color: #fc5d7b;
}
.products .convert b{
    font-weight: bold;
}
.products .cb{
    position: absolute;
    right: 0;
    top: 0;
    width: 52px;
    height: 104px;
}
.products .cb label{
    position: absolute;
    width: 100%;
    height: 100%;
}
.products .cb input{
    position: absolute;
    display: none;
    top: 43px;
    left: 20px;
}
.products .cb i{
    position: absolute;
    top: 40px;
    left: 17px;
    display: block;
    width: 24px;
    height: 24px;
    background: url(/static/img/mobile_tp/checkbox.png) no-repeat;
    background-position: 0 -25px;
    background-size: 24px 49px;
}
.products .cb input[type=checkbox]:checked + label i{
    background-position: 0 0;
}
.products-hide ul{
    display: none;
}
.products-hide .title{
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
}
.products-hide .title::after{
    background-position: 0 -88px;
}

/* Cart */
.cart{
    color: #fff;
    background-color: rgba(92, 92, 92, 0.9);
    -webkit-box-shadow: 0px 2px 0px rgba(92, 92, 92, 0.12);
    box-shadow:         0px 2px 0px rgba(92, 92, 92, 0.12);
    border-bottom-right-radius: 4px;
    border-bottom-left-radius: 4px;
    border-top-right-radius: 4px;
    border-top-left-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    position: fixed;
    bottom: 13px;
    right: 15px;
    height: 44px;
    line-height: 44px;
    font-size: 15px;
    -webkit-text-shadow: 0px 2px 0px rgba(0, 0, 0, 0.12);
    text-shadow:         0px 2px 0px rgba(0, 0, 0, 0.12);
}
.cart-icon{
    font-weight: bolder;
    display: inline-block;
    width: 44px;
    height: 44px;
    vertical-align: middle;
    position: relative;
}
.cart .icon-bg{
    line-height: 20px;
    position: absolute;
    right: -2px;
    top: -6px;
    text-align: center;
    font-size: 12px;
}
.cart-text{
    display: none;
    margin-right: 9px;
}
.cart-icon i{
    width: 24px;
    height: 24px;
    display: inline-block;
    position: absolute;
    top: 10px;
    left: 10px;
    background-image: url(/static/img/mobile_tp/cart.png);
    background-repeat: no-repeat;
    background-size: 24px 49px;
    background-position: 0 -24px;
}
.cart-init .cart-text{
    display: inline-block;
}
.cart-init i{
    background-position: 0 0;
}

#expiredCounting {
    font-size: 14px;
}
/* 覆盖掉编辑使用的富文本时自带的默认样式 */
/* rich text cover start */
.list-paddingleft-2 {
    margin-left: 20px;
}
/* rich text cover end */

/* App Banner */
.m-app-download .download-banner {
  position: fixed;
  top: 0;
  width: 100%;
  max-width: 600px;
  height: 60px;
  z-index: 10000;
  -webkit-background-size: cover !important;
  background-size: cover !important;
}
.m-app-download .download-divide {
  height: 80px;
  width: 100%;
}
.m-app-download .download-bg {
  background: url(/static/img/mobile/common/app_download_banner.png?v=20140611) no-repeat;
  -webkit-background-size: 320px auto;
  background-size: 320px auto;
}
.m-app-download .icon-logo {
  background-position: 0 -70px;
  width: 47px;
  height: 47px;
  position: absolute;
  left: 10px;
  top: 6px;
}
.m-app-download .icon-button {
  background-position: -75px -70px;
  width: 89px;
  height: 28px;
  position: absolute;
  right: 15px;
  top: 16px;
}
.m-app-download .icon-text {
  position: absolute;
  left: 66px;
  top: 15px;
  width: 127px;
  height: 29px;
}
.m-app-download .icon-text-product {
  background-position: 0 -170px;
}

.popup-subproduct{
    display: none;
}
.popup-subproduct .box{
    margin: 0;
    padding: 0;
    border:0;
}
.popup-subproduct .box h2{
    text-align: left;
    height: 20px;
    line-height: 20px;
    padding-top: 0;
    margin-bottom: 5px;
}
.popup-subproduct .box h2 a{
    float: right;
}
.popup-subproduct .sub-products {
    padding-bottom: 0;
}
#sub-products-scroll{
    height: 282px;
    position: relative;
}
#sub-products-scroll.scrollable .sub-products{
    height: 282px;
    overflow-y: scroll;
    overflow-x: hidden; 
    -webkit-overflow-scrolling: touch;
}
.popup-subproduct .sub-products li{
    margin: 0;
    padding: 12px 0;
    border-bottom: 1px dotted #c9c9c9;
}
.popup-subproduct .sub-products li:last-child{
    padding-bottom: 0;
    border-bottom: 0;
}
.popup-subproduct .sub-products-price{
    height: 54px;
    width: 83px;
    padding-left: 18px;
    border-left: 1px solid #e7e5df;
}
.popup-subproduct .sub-products-price p{
    padding: 0 0 9px;
}
.popup-subproduct  .sub-products-title{
    padding: 0;
    padding-right: 10px;
    text-align: left;
}
/* App Banner end */
